Namespaces
Variants

std::literals::chrono_literals:: operator""y

From cppreference.net
Definiert im Header <chrono>
constexpr std:: chrono :: year operator "" y ( unsigned long long y ) noexcept ;
(seit C++20)

Bildet ein std::chrono::year Literal, das ein Jahr im proleptischen gregorianischen Kalender repräsentiert.

Inhaltsverzeichnis

Parameter

y - der Jahreswert

Rückgabewert

Ein std::chrono::year initialisiert aus int ( y ) . Wenn y nicht im Bereich [ - 32767 , 32767 ] liegt, ist der gespeicherte Wert nicht spezifiziert.

Mögliche Implementierung

constexpr std::chrono::year operator""y(unsigned long long y) noexcept
{
    return std::chrono::year(static_cast<int>(y));
}

Hinweise

Dieser Operator ist im Namensraum std :: literals :: chrono_literals deklariert, wobei sowohl literals als auch chrono_literals Inline-Namensräume sind. Der Zugriff auf diesen Operator kann erfolgen durch:

  • using namespace std :: literals ,
  • using namespace std :: chrono_literals , oder
  • using namespace std :: literals :: chrono_literals .

Zusätzlich wird innerhalb des Namespace std :: chrono die Direktive using namespace literals :: chrono_literals ; von der Standardbibliothek bereitgestellt, sodass wenn ein Programmierer using namespace std :: chrono ; verwendet, um Zugriff auf die Klassen in der Chrono-Bibliothek zu erhalten, die entsprechenden Literaloperatoren ebenfalls sichtbar werden.

Beispiel

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::literals;
    std::cout << int(2020y)  << '\t' << 2020y  << '\n'
              << int(-220y)  << '\t' << -220y  << '\n'
              << int(3000y)  << '\t' << 3000y  << '\n'
              << int(32768y) << '\t' << 32768y << '\n'  // unspecified
              << int(65578y) << '\t' << 65578y << '\n'; // unspecified
}

Mögliche Ausgabe:

2020	2020
-220	-0220
3000	3000
-32768	-32768 is not a valid year
42	0042

Siehe auch

konstruiert ein year
(öffentliche Mitgliedsfunktion von std::chrono::year )